<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>vue.set</title>
  <script src="../vue.js"></script>
</head>

<body>
  <div id="app">
    <p v-for="(l,i) in items" :key="i">
      {{l}}
    </p>
    <button @click="addProperty">动态添加新属性</button>
  </div>

  <script>
    // const app = new Vue({
    //   el:'#app',
    //   // data:{

    //   // }
    //   data(){
    //     return {

    //     }
    //   }
    // })

    const app = new Vue({
      el: "#app",
      data() {
        return {
          items: {
            oldProperty: "旧属性"
          }
        }
      },
      // methods: {
      //   addProperty() {
      //     this.items.newProperty = "新属性"  // 为items添加新属性
      //     console.log(this.items)  // 输出带有newProperty的items
      //     this.$forceUpdate();
      //   }
      // }
      methods: {
        addProperty() {
          this.$set(this.items,'newProperty','xxxx')
        }
      }
    })
  </script>
</body>

</html>